package cn.tedu.csmall.product.service.impl;

import cn.tedu.csmall.product.ex.ServiceException;
import cn.tedu.csmall.product.mapper.AlbumMapper;
import cn.tedu.csmall.product.mapper.PictureMapper;
import cn.tedu.csmall.product.mapper.SpuMapper;
import cn.tedu.csmall.product.pojo.dto.AlbumAddNewDTO;
import cn.tedu.csmall.product.pojo.dto.AlbumUpdateDTO;
import cn.tedu.csmall.product.pojo.entity.Album;
import cn.tedu.csmall.product.pojo.vo.AlbumListItemVO;
import cn.tedu.csmall.product.pojo.vo.AlbumStandardVO;
import cn.tedu.csmall.product.service.IAlbumService;
import cn.tedu.csmall.product.web.ServiceCode;
import lombok.Data;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

@Slf4j
@Service
public class AlbumServiceImpl implements IAlbumService {

    @Autowired
    private AlbumMapper albumMapper;
    @Autowired
    private PictureMapper pictureMapper;
    @Autowired
    private SpuMapper spuMapper;

    public AlbumServiceImpl() {
        log.debug("创建业务对象: AlbumServiceImpl");
    }

    @Override
    public void addNew(AlbumAddNewDTO albumAddNewDTO) {
        log.debug("开始处理添加相册业务,参数: {}", albumAddNewDTO);
        //从参数对象中获取相册名称
        String albumName = albumAddNewDTO.getName();
        //检查相册名称是否已经被占用（相册表中是否已经存在此名称的数据）
        log.debug("检查相册名称是否已经被占用");
        int count = albumMapper.countByName(albumName);
        if(count>0){
            //是: 相册名称已经被占用,添加相册失败,抛出异常
            String message = "添加相册失败，相册名称已经被占用！";
            log.debug(message);
            throw new ServiceException(ServiceCode.ERR_CONFLICT,message);
        }

        //否: 相册名称没有被占用, 则向相册表中插入数据
        log.debug("相册名称没有被占用,将向相册表中插入数据");
        Album album = new Album();
        //album.getName().toLowerCase();
        BeanUtils.copyProperties(albumAddNewDTO,album);
        log.debug("即将插入相册数据:{}",album);
        int rows = albumMapper.insert(album);
        if (rows != 1) {
            String message = "添加相册失败，服务器忙，请稍后再尝试！";
            log.debug(message);
            throw new ServiceException(ServiceCode.ERR_INSERT, message);
        }
        log.debug("插入相册数据完成");
        }

    @Override
    public void delete(Long id){
        log.debug("开始处理[根据id删除相册]的业务,参数: {}", id);
            // 调用Mapper对象的getStandardById()执行查询
            AlbumStandardVO queryResult = albumMapper.getStandardById(id);
            if(queryResult == null){
                // 是：无此id对应的数据，将不允许执行删除操作，则抛出异常
                String message = "删除相册失败,尝试访问的数据不存在! ";
                log.debug(message);
                throw new ServiceException(ServiceCode.ERR_NOT_FOUND, message);
            }

            {
                // 检查是否存在图片（picture）关联到此相册，如果存在，则不允许删除
                int count = pictureMapper.countByAlbumId(id);
                if (count > 0) {
                    String message = "删除册失败,此相册存在关联的图片数据! ";
                    log.debug(message);
                    throw new ServiceException(ServiceCode.ERR_CONFLICT, message);
                }
            }
            {
                // 检查是否存在SPU关联到此相册，如果存在，则不允许删除
                int count = spuMapper.countByAlbumId(id);
                if(count > 0){
                    String message = "删除相册失败,此相册存在关联的SPU数据! ";
                    log.debug(message);
                    throw new ServiceException(ServiceCode.ERR_CONFLICT, message);
                }
            }
            // 调用Mapper对象的deleteById()方法执行删除
            log.debug("即将执行删除,参数:{}", id);
            int rows = albumMapper.deleteById(id);
            if (rows != 1) {
                String message = "添加类别失败，服务器忙，请稍后再尝试！";
                log.debug(message);
                throw new ServiceException(ServiceCode.ERR_DELETE, message);
            }
        }

    @Override
    public void updateById(Long id, AlbumUpdateDTO albumUpdateDTO) {
        log.debug("开始处理[根据id修改相册]的业务,参数: {}", albumUpdateDTO);
        // 调用Mapper对象的getStandardById()执行查询
        AlbumStandardVO queryResult = albumMapper.getStandardById(id);
        if (queryResult == null) {
            // 是：无此id对应的数据，将不允许执行修改操作，则抛出异常
            String message = "修改相册失败,尝试访问的数据不存在! ";
            log.debug(message);
            throw new ServiceException(ServiceCode.ERR_NOT_FOUND, message);
        }

        log.debug("检查相册名称是否已经被占用");
        {
        int count = albumMapper.countByNameAndNotId(id, albumUpdateDTO.getName());
        if (count > 0) {
            //是: 相册名称已经被占用,修改相册失败,抛出异常
            String message = "修改相册失败，相册名称已经被占用！";
            log.debug(message);
            throw new ServiceException(ServiceCode.ERR_CONFLICT, message);
            }
        }

        Album album = new Album();
        BeanUtils.copyProperties(albumUpdateDTO, album);
        album.setId(id);

            // 调用Mapper对象的updateById()方法执行修改
            log.debug("即将执行修改,参数:{}", album);
            int rows = albumMapper.update(album);
            if (rows != 1) {
                String message = "修改相册失败，服务器忙，请稍后再尝试！";
                log.debug(message);
                throw new ServiceException(ServiceCode.ERR_DELETE, message);
        }
    }


    @Override
    public AlbumStandardVO getStandardById(Long id) {
        log.debug("开始处理[根据id查询相册详情]的业务,参数: {}", id);
        // 调用Mapper对象的getStandardById()执行查询
        AlbumStandardVO queryResult = albumMapper.getStandardById(id);
        if(queryResult == null){
            // 是：无此id对应的数据，将不允许执行查询操作，则抛出异常
            String message = "查询相册详情失败,尝试访问的数据不存在! ";
            log.debug(message);
            throw new ServiceException(ServiceCode.ERR_NOT_FOUND, message);
        }
        // 调用Mapper对象的getStandardById()方法执行查询
        return queryResult;

    }

    @Override
    public List<AlbumListItemVO> list() {
        log.debug("开始处理[查询相册列表]的业务,无参数");
        return albumMapper.list();
    }
}

